D:\a\tools.proto\tools.proto\compiler\src\gen\base\message_write.rs
Line | Count | Source |
1 | | // Copyright (c) 2024, BlockProject 3D |
2 | | // |
3 | | // All rights reserved. |
4 | | // |
5 | | // Redistribution and use in source and binary forms, with or without modification, |
6 | | // are permitted provided that the following conditions are met: |
7 | | // |
8 | | // * Redistributions of source code must retain the above copyright notice, |
9 | | // this list of conditions and the following disclaimer. |
10 | | // * Redistributions in binary form must reproduce the above copyright notice, |
11 | | // this list of conditions and the following disclaimer in the documentation |
12 | | // and/or other materials provided with the distribution. |
13 | | // * Neither the name of BlockProject 3D nor the names of its contributors |
14 | | // may be used to endorse or promote products derived from this software |
15 | | // without specific prior written permission. |
16 | | // |
17 | | // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |
18 | | // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT |
19 | | // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR |
20 | | // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR |
21 | | // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, |
22 | | // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, |
23 | | // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR |
24 | | // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF |
25 | | // LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING |
26 | | // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS |
27 | | // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
28 | | |
29 | | use crate::compiler::message::{Field, Message}; |
30 | | use crate::compiler::util::types::TypeMapper; |
31 | | use crate::gen::base::map::TypePathMapper; |
32 | | use crate::gen::base::message::{Templates, Utilities}; |
33 | | use crate::gen::base::message_common::generate_field_type_inline; |
34 | | use crate::gen::base::Error; |
35 | | |
36 | 66 | fn gen_field_write_impl<U: Utilities, T: TypeMapper>( |
37 | 66 | field: &Field, |
38 | 66 | templates: &Templates, |
39 | 66 | type_path_map: &TypePathMapper<T>, |
40 | 66 | function: &str, |
41 | 66 | ) -> Result<String, Error> { |
42 | 66 | let mut scope = templates.template.scope(); |
43 | 66 | scope.var("name", &field.name); |
44 | 66 | let codec_template = templates.get(field.codec())?0 ; |
45 | 66 | let msg_type = generate_field_type_inline::<U, T>(field, codec_template, type_path_map, "write")?0 ; |
46 | 66 | if let Some(header13 ) = &field.header { Branch (46:12): [True: 13, False: 53]
Branch (46:12): [True: 0, False: 0]
Branch (46:12): [Folded - Ignored]
|
47 | 13 | scope.var("header_name", &header.name); |
48 | 53 | } |
49 | 66 | scope.var("type", msg_type); |
50 | 66 | if field.header.is_some() && field.ty.is_union()13 { Branch (50:8): [True: 13, False: 53]
Branch (50:34): [True: 9, False: 4]
Branch (50:8): [True: 0, False: 0]
Branch (50:34): [True: 0, False: 0]
Branch (50:8): [Folded - Ignored]
Branch (50:34): [Folded - Ignored]
|
51 | 9 | Ok(scope.render(function, &["field_union"]).unwrap()) |
52 | 57 | } else if field.header.is_some() { Branch (52:15): [True: 4, False: 53]
Branch (52:15): [True: 0, False: 0]
Branch (52:15): [Folded - Ignored]
|
53 | 4 | Ok(scope.render(function, &["field_header"]).unwrap()) |
54 | 53 | } else if field.ty.is_string() { Branch (54:15): [True: 18, False: 35]
Branch (54:15): [True: 0, False: 0]
Branch (54:15): [Folded - Ignored]
|
55 | 18 | Ok(scope.render(function, &["field_string"]).unwrap()) |
56 | | } else { |
57 | 35 | Ok(scope.render(function, &["field"]).unwrap()) |
58 | | } |
59 | 66 | } |
60 | | |
61 | 35 | pub fn generate<'variable, U: Utilities, T: TypeMapper>( |
62 | 35 | mut templates: Templates<'_, 'variable>, |
63 | 35 | msg: &'variable Message, |
64 | 35 | type_path_map: &TypePathMapper<T>, |
65 | 35 | function: &str, |
66 | 35 | ) -> Result<String, Error> { |
67 | 35 | templates.template.var("msg_name", &msg.name); |
68 | 35 | let fields = msg |
69 | 35 | .fields |
70 | 35 | .iter() |
71 | 66 | .map(|field| gen_field_write_impl::<U, T>(field, &templates, type_path_map, function)) |
72 | 35 | .collect::<Result<Vec<String>, Error>>()?0 |
73 | 35 | .join(""); |
74 | 35 | Ok(templates.template.var("fields", fields).render("", &[function]).unwrap()) |
75 | 35 | } |